<template>
  <div class="hello">
    <Header></Header>

    <!-- 展示常规项目 -->
    <ShowRegularItem
      :item_info="item_info"
      :search_item="search_item"
      :keyword="keyword"
      v-if="item_info && (item_info.item_type == 1 || item_info.item_type == 3 || item_info.item_type === '0' || item_info.item_type === 0 ) "
    ></ShowRegularItem>

    <!-- 展示单页项目 -->
    <ShowSinglePageItem :item_info="item_info" v-if="item_info && item_info.item_type == 2 "></ShowSinglePageItem>

    <!-- 展示表格项目 -->
    <ShowTableItem :item_info="item_info" v-if="item_info && item_info.item_type == 4 "></ShowTableItem>

    <Footer></Footer>
  </div>
</template>



<script>
import ShowRegularItem from '@/components/item/show/show_regular_item/Index'
import ShowSinglePageItem from '@/components/item/show/show_single_page_item/Index'
import ShowTableItem from '@/components/item/show/show_table_item/Index'

export default {
  data() {
    return {
      item_info: '',
      keyword: ''
    }
  },
  components: {
    ShowRegularItem,
    ShowSinglePageItem,
    ShowTableItem
  },
  methods: {
    // 获取菜单
    get_item_menu(keyword) {
      if (!keyword) {
        keyword = ''
      }
      var that = this
      var loading = that.$loading()
      var item_id = this.$route.params.item_id ? this.$route.params.item_id : 0
      var page_id = this.$route.query.page_id ? this.$route.query.page_id : 0
      let params = {
        'item_id': item_id,
        'keyword': keyword
      }
      if (!keyword) {
        params.default_page_id = page_id
      }
      this.request('/api/item/info', params, 'post', false).then((data) => {
        loading.close()
        if (data.error_code === 0) {
          var json = data.data
          if (json.default_page_id <= 0) {
            if (json.menu.pages[0]) {
              json.default_page_id = json.menu.pages[0].page_id
            }
          }
          // 如果是runapi类型项目，则去掉编辑权限。只允许在runapi里编辑
          if (json.item_type == 3) {
            json.ItemCreator = json.ItemPermn = false
          }
          that.item_info = json
          document.title = that.item_info.item_name + '--ShowDoc'
          if (json.unread_count > 0) {
            that.$message({
              showClose: true,
              duration: 10000,
              dangerouslyUseHTMLString: true,
              message: '<a href="#/notice/index">你有新的未读消息，点击查看</a>'
            })
          }
        } else if (
          data.error_code === 10307 ||
          data.error_code === 10303
        ) {
          // 需要输入密码
          that.$router.replace({
            path: '/item/password/' + item_id,
            query: {
              page_id: page_id,
              redirect: that.$router.currentRoute.fullPath
            }
          })
        } else {
          that.$alert(data.error_message)
        }
      })

      // 设置一个最长关闭时间
      setTimeout(() => {
        loading.close()
      }, 20000)
    },
    search_item(keyword) {
      this.item_info = ''
      this.keyword = keyword
      this.get_item_menu(keyword)
    },
    checkDb() {
      var url = DocConfig.server + '/api/update/checkDb'
      this.axios.get(url)
    }
  },
  mounted() {
    this.checkDb()
    this.get_item_menu()
  },
  beforeDestroy() {
    this.$message.closeAll()
    document.title = 'ShowDoc'
  }
}
</script>

<!-- Add "scoped" attribute to limit CSS to this component only -->
<style scoped>
</style>
